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DETAILED ACTION 
Response to Arguments 
Applicant's arguments, filed on 4/24/07, have been considered but are moot in view of 
new grounds of rejection, A new 103 rejection is being presented using Bonola (2001/001 1338) 
in view of Applicant's Admitted Prior Art (Page 1 of Applicant's Specification). 

Claim Rejections - 35 USC §103 
1. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

1, Claims 1-34 are rejected under 35 U.S.C. 103(a) as being obvious over Bonola 

(2001/001 1338) in view of Applicant's Admitted Prior Art (Page 1 of Specification). 

Regarding Claim 1, Bonola discloses a method comprising: 

receiving a set of data (in the process of executing an instruction within an application 
program, paragraph 00 1 3); 

determining whether a free entry of a size required by a portion of the set of data exists in 
one of a plurality of sections of a memory (executes HeapAlloc... examine heap data structure 
[to] determine if there is an appropriately sized heap sub-region in the fi-ee list wherein the free 
list contains unassigned heap sub-regions, paragraph 0037); 

determining whether the memory includes one or more sections of an unallocated size 
(unassigned heap sub-region, paragraph 0034-0035); and 
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if a free group entry of the size required by the portion of the set of data does not exist in 
one of the plurality of sections of the memory (if N exceeds M, then there is no heap sub-region 
within the heap that can accommodate the demand..., paragraph 0038), determining whether the 
memory includes one or more sections of an unallocated size; and if the memory includes one or 
more sections of an unallocated size, allocating one of the sections of an unallocated size to the 
size required by the portion of the set of data thereby creating a section of a dynamically 
allocated size, the section of the dynamically allocated size including one or more group entries 
of the size required by the portion of the set of data (see paragraph 039, address of the higher 
memory address is entered into the N list of the free list... of the remaining half of the heap sub- 
region contains twice as much memory as is required by the requesting application, the 
remaining half of the heap sub-region can be further divided in half. . , steps are repeated until a 
heap sub-region is yielded which does not have twice as much memory as is required. The sub- 
region is then assigned to the application). 

The unallocated memory of Bonola's invention is not allocated to an application, 
however, it is allocated to a heap data structure holding free memory areas. 

Bonola does not teach the storage of group entries and the memory being pre-allocated 
with a group size. Applicant's Admitted Prior Art discloses the storage of data using group 
entries and pre-allocating the memory by dividing the memory into one or more sections of an 
anticipated group size (Specification, page 1, paragraph 2). It would have been obvious to one of 
ordinary skill in the art at the time the invention was made to modify the system of Bonola to 
include the storage of data using group entries and the pre-allocation of memory with a group 
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size since this method of memory allocation provides for efficient allocation for networked 
systems. 

Regarding Claim 2, Bonola discloses a method wherein determining whether a free group 
entry of the size required by the portion of the set of data exists in one of a plurality of sections 
of the memory includes determining whether a free group entry of the size required by the 
portion of the set of data for uniquely identifying each portion of the set of data exists in one of 
the plurality of sections of memory (...no heap sub-region within heap 302 can accommodate a 
demand for X bytes of memory from application 202, paragraph 0038 wherein the memory is 
allocated to the heap data structure). 

Regarding Claim 3, Bonola discloses a method wherein determining whether the memory 
includes one or more sections of an unallocated size includes accessing a control structure for 
one or more sections of the memory, the control structure storing information about the structure 
of a section (heap data structure 304). 

Regarding Claim 4, Bonola discloses a method further comprising, from the section of a 
dynamically allocated size, allocating an initial group entry of the size required by the portion of 
the set of data for storing the portion of the set of data (... the address of the heap sub-region 
contained in the entry is then assigned to the application, paragraph 0037) 

Regarding Claim 5, Bonola discloses a method further comprising: receiving a modified 
set of data; determining whether a portion of the modified set of data may be stored more 
efficiently in a group entry of a different size from another section of the memory such that the 
aggregate number of unused entries in the group entries used for storing the modified set of data 
is minimized (...if the remaining half of the heap sub-region contains twice as much memory as 
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is required by the requesting application, the remaining half of the heal' sub-region can be further 
divided..., paragraph 0039); allocating a group entry of the different size required by the portion 
of the modified set of data from another section of the memory to store the portion of the 
modified set of data (repeating steps 532-540 until a heap sub-region is yielded which does not 
have twice as much memory as is required and then assigning the sub-region to the application. . . 
paragraph 0039); and de-allocating the initial group entry to the section of memory from which 
the initial group entry was allocated (wherein de-allocation of the initial group entry occurs when 
the newly selected heap sub-region is placed in the N list and replaces the initial entry. Figure 5). 

Regarding Claim 6, Bonola discloses a method further comprising updating the control 
structure that stores information about the structure of the other section (...an entry is removed 
from the N list in the free list 306, paragraph 0038). 

Regarding Claim 7, Bonola discloses a method further comprising updating the control 
structure that stores information about the structure of the section of memory from which the 
initial group entry was allocated (...an entry is removed from the N list in the free list 306, 
paragraph 0038). 

Regarding Claim 8, Bonola discloses a method wherein de-allocating the initial group 
entry to the section of memory from which the initial group entry was allocated leaves all entries 
of the section unused (when the application is finished using an assigned heap sub-region, it can 
return the heap sub-region to the heap using the HeapFree instruction, thus leaving those entries 
unused, paragraph 0040). 
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Regarding Claim 9, Bonola discloses a method further comprising clearing the group 
entry size allocation of the section (HeapFree instruction clears the allocation of the sections 
since the heap contains unassigned memory, paragraph 0040-0041). 

Regarding Claim 10, Bonola discloses a method further comprising, if the memory does 
not include one or more sections of an unallocated size, determining whether a free group entry 
of a size larger than the size required by the portion of the data exists (Paragraph 0039, heap sub- 
region with the higher memory address is entered into the N list. . .), wherein sections allocated to 
the smallest available size larger than the size required by the portion of the data are checked 
prior to sections allocated to larger available sizes (continue dividing sub-region in half until 
sub-region contains less than twice as much memory as required). 

Regarding Claim 11, Bonola discloses a method further comprising, if a free group entry 
of a size larger than the size required by the portion of the data exists in a section allocated to a 
size larger than the size required by the portion of data, allocating an initial group entry of the 
size larger than the size required by the portion of the set of data from the section allocated to a 
size larger than the size required by the portion of the data for storing the portion of the set of 
data (paragraph 0039, if the sub-region contains less than twice as much memory as needed... 
the sub-region should be assigned). 

Regarding Claim 12, Bonola discloses a method further comprising, if a free group entry 
of a size larger than the size required by the portion of the data does not exist outputting an error 
condition (Paragraph 0038, there is no sub-region within the heap that can accommodate a 
demand for X bytes... HeapAUoc instruction will fail...). 

Claim 13 is rejected using the same rationale as that of Claim 5 . 
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Claim 14 is rejected using the same rationale as that of Claim 6. 

Claim 15 is rejected using the same rationale as that of Claim 7. 

Claim 16 is rejected using the same rationale as that of Claim 8. 

Claim 17 is rejected using the same rationale as that of Claim 9. 

Claim 18 is rejected using the same rationale as that of Claim 1 wherein the memory is 
represented by system memory 114, the plurality of registers are within heap data structure 304, 
and the dynamic allocation logic is equivalent to the method for dynamically allocating memory 
in a computer system of the invention (paragraph 0013, and Figure 3). 
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Claim 33 is rejected using the same rationale as that of Claim 8. 



Claim 34 is rejected using the same rationale as that of Claim 9. 



Conclusion 



Any inquiry concerning this communication or earlier communications from the exam 
iner should be directed to Midys Rojas whose telephone number is (571) 272-4207. The 
examiner can normally be reached on M-F 5:30am - 4:00pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Sanjiv Shah can be reached on (571) 272-4098. The fax phone number for the 
organization where this application or proceeding is assigned is 571-273-8300, 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). If you would 
like assistance from a USPTO Customer Service Representative or access to the automated 
information system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 



MR 




